#include <bits/stdc++.h>
using namespace std;
int n,k;
const int N=2e5+10;
int h[N],w[N];
bool check(int len){
int num=0;
for(int i=1;i<=n;i++){
num += (h[i]/len)*(w[i]/len);
}
if(num>=k){
return true;
}else{
return false;
}
}
int main(){
cin>>n>>k;
for(int i=1;i<=n;i++){
cin>>h[i]>>w[i];
}
int l=1,r=1e6+10,ans=0;
while(l<=r){
int mid=(l+r)/2;
if(check(mid)){
ans=mid;
l=mid+1;
}else{
r=mid-1;
}
}
cout<<ans;
return 0;
}